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Please amend the claims as follows (this listing replaces all prior versions): 

1. (Currently Amended) A method comprising: 

identifying a plurality of memory resources for pushing data to and pulling data from a 
processing agent; 

when pushing data to the processing agent, 

using a push bus arbiter to arbitrate use of a push bus by the memory resources in 
which requests for using the push bus are sent from the memory resources , and 

pushing the data from the memory resources to the processing agent through the 
push bus, the memory resources obtaining access to the push bus based on arbitration by the 
push bus arbiter; and 

when pulling data from the processing agent, 

using a pull bus arbiter to arbitrate use of a pull bus by the memory resources in 
which requests for using the pull bus arc sent from the memory resources , 
executing a context, 
issuing a write command, 

loading data into an output transfer memory of the processing agent, 

setting the output transfer memory to a read-only state, and 

pulling the data from the output transfer memory and transferring to the memory 

resources through the pull bus, the memory resources obtaining access to the pull bus based on 

arbitration by the pull bus arbiter. 

2. (Previously Presented) The method of claim 1 further comprising: 
establishing a plurality of contexts on the processing agent and maintaining program 

counters and context relative registers. 

3. (Previously Presented) The method of claim 2 wherein the processing agent 
executes a context and issues a read command to a memory controller in a read phase. 



Applicant : Gilbert Wolrich et al. Attorney's Docket No.: 10559-618001 / P12857 

Serial No. : 10/057,738 
Filed : January 25, 2002 
Page : 3 of 15 

4. (Previously Presented) The method of claim 3 wherein the memory controller 
processes the read command to be sent to one of the memory resources. 



5. (Original) The method of claim 4 wherein the context is swapped out if the read 
data is required to continue the execution of the context. 

6. (Previously Presented) The method of claim 5 wherein after the memory 
controller has completed the processing of the read command, the memory controller pushes the 
data to an input transfer memory of the processing agent. 

7. (Previously Presented) The method of claim 58 wherein after the data has been 
pushed, the processing agent reads the data in the input transfer register and the processing agent 
continues the execution of the context. 



8-12. (Cancelled) 



13. (Currently Amended) A system comprising: 

a plurality of memory resources, each memory resource being associated with a memory 
controller; 

a processing agent to access the memory resources; 

a unidirectional push bus to push data from the memory resources to the processing 

agent; 

a push bus arbiter to arbitrate use of the push bus by the memory resources in which 
requests for using the push bus are sent from the memory resources , the memory resources 
obtaining access to the push bus based on arbitration by the push bus arbiter; 

a unidirectional pull bus to receive data from the processing agent and to transfer the data 
to the memory resources; and 

a pull bus arbiter to arbitrate use of the pull bus by the memory resources in which 
requests for using the pull bus are sent from the memory resources , the memory resources 
obtaining access to the pull bus based on arbitration by the pull bus arbiter. 
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14-15. (Cancelled) 

16. (Original) The system of claim 13 further comprising a plurality of program 
counters and a plurality of context relative registers. 

17. (Original) The system of claim 16 in which the context relative registers are 
selected from a group comprising of general purpose registers, inter-programming agent 
registers, static random access memory (SRAM) input transfer registers, dynamic random access 
memory (DRAM) input transfer registers, SRAM output transfer registers, DRAM output 
transfer registers, and local memory registers. 

18. (Previously Presented) The system of claim 17 in which the processing agent is 
to execute a context and issue a read command to a memory controller. 

19. (Original) The system of claim 18 in which the memory controller is to process 
the read command to be sent to the memory resource. 

20. (Previously Presented) The system of claim 19 in which the processing agent is 
to swap the context out if the read command is required to continue to execution of the context. 

21 . (Previously Presented) The system of claim 20 in which after the read command 
is processed, the memory controller is to push the data to an input transfer register of the 
processing agent and the processing agent is to read the data in the input transfer register and to 
continue the execution of the context. 

22-25. (Cancelled) 

26. (Currently Amended) A machine-accessible medium, which when accessed 
results in a machine performing operations comprising: 
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identifying a plurality of memory resources for pushing data to and pulling data from a 
processing agent, each memory resource being associated with a memory controller; 
when pushing data to the processing agent, 

using a push bus arbiter to arbitrate use of a push bus by the memory resources jn 
which requests for using the push bus are sent from the memory resources , 

pushing the data from the memory resources to the processing agent through the 
push bus, the memory resources obtaining access to the push bus based on arbitration by the 
push bus arbiter, 

when pulling data from the processing agent, 

using a pull bus arbiter to arbitrate use of a pull bus by the memory resources jn 
which requests for using the pull bus are sent from the memory resources , 
executing a context, 
issuing a write command, 

loading data into an output transfer memory of the - processing agont, 

sotting the output transfer memory to a road only state, and 

pulling data from the output transfer memory and transferring the data to the 

memory resources through the pull bus, the memory resources obtaining access to the pull bus 

based on arbitration by the pull bus arbiter. 

27. (Previously Presented) The machine-accessible medium of claim 26, which when 
accessed further results in the machine performing operations comprising establishing a plurality 
of contexts on the processing agent and maintaining program counters and context relative 
registers. 

28. (Previously Presented) The computer program product of claim 26 wherein the 
processing agent in a read phase executes a context and issues a read command to a memory 
controller. 
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29. (Original) The computer program product of claim 26 wherein the memory 
controller processes the read command to be sent to the memory resource and the context is 
swapped out if the read command is required to continue the execution of the context. 

30-32. (Cancelled) 

33. (Previously Presented) The method of claim 1 wherein the context is swapped 
out if the write command is required to continue the execution of the context. 

34. (Previously Presented) The method of claim 33 wherein the memory controller 
pulls the data from the output transfer memory and the memory controller sends a signal to the 
processing agent to unlock the output transfer memory. 

35. (Previously Presented) The method of claim 34 wherein if the context has been 
swapped out after the output transfer memory has been unlocked, the context is swapped back in 
and the processing agent continues the execution of the context. 

36. (Cancelled) 

37. (Currently Amended) A system comprising: 

a plurality of memory resources, each memory resource being associated with a memory 
controller; 

a processing agent to access the memory resources; 

a push bus to push data from the memory resources to the processing agent; 

a push bus arbiter to arbitrate use of the push bus by the memory resources in which 
requests for using the push bus are sent from the memory resources , the memory resources 
obtaining access to the push bus based on arbitration by the push bus arbiter; 

a pull bus to receive data from the processing agent and to transfer the data to the 
memory resources; and 
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a pull bus arbiter to arbitrate use of the pull bus by the memory resources in which 
requests for using the pull bus are sent from the memory resources , the memory resources 
obtaining access to the pull bus based on arbitration by the pull bus arbiter; 

wherein the processing agent is to execute a context and load the data into an output 
transfer memory of the processing agent, and to issue a write command to a memory controller 
and in which the output transfer memory is set to a read-only state. 

38-39. (Cancelled) 

40. (Previously Presented) The system of claim 37 in which the processing agent is 
to swap the context out of the write command is required to continue to execution of the context. 

41 . (Previously Presented) The system of claim 40 in which the memory controller is 
to push the data from the output transfer memory and to send a signal to the processing agent to 
unlock the output transfer memory. 

42. (Cancelled) 

43. (Previously Presented) The method of claim 1, wherein the memory resources 
comprise memory controller channels. 

44. (Previously Presented) The system of claim 13, wherein the memory resources 
comprise memory controller channels. 

45. (Previously Presented) The machine accessible medium of claim 26, wherein the 
memory resources comprise memory controller channels. 

46-48. (Cancelled) 



49. 



(Currently Amended) A method comprising: 
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identifying a plurality of memory resources for pushing data to and pulling data from a 
processing agent; 

using a push bus arbiter to arbitrate use of a unidirectional push bus by the memory 
resources in which requests for using the unidirectional push bus are sent from the memory 
resources ; 

pushing the data from the memory resources to the processing agent through the push 
bus, the memory resources obtaining access to the push bus based on arbitration by the push bus 
arbiter; 

using a pull bus arbiter to arbitrate use of a unidirectional pull bus by the memory 
resources in which requests for using the unidirectional pull bus are sent from the memory 
resources ; and 

pulling the data from the processing agent and transferring to the memory resources 
through the pull bus, the memory resources obtaining access to the pull bus based on arbitration 
by the pull bus arbiter. 

50. (Previously Presented) The method of claim 49, further comprising executing a 
context and issuing a read command to a memory controller to read data from one of the memory 
resources. 

5 1 . (Previously Presented) The method of claim 50, further comprising swapping out 
the context if the data to be read is required to continue the execution of the context. 

52. (Canceled) 

53. (Previously Presented) The method of claim 49, further comprising executing a 
context and issuing a write command to a memory controller to write data to one of the memory 
resources. 
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54. (Previously Presented) The method of claim 53, further comprising swapping out 
the context if completion of the write command is required to continue the execution of the 
context. 

5 5 . (Currently Amended) A data processor comprising : 

a push bus arbiter to arbitrate use of a unidirectional push bus by a plurality of memory 
resources in which requests for using the unidirectional push bus are sent from the memory 
resources , the unidirectional push bus allowing the memory resources to push data from the 
memory resources; and 

a pull bus arbiter to arbitrate use of a unidirectional pull bus by the memory resources in 
which requests for using the unidirectional pull bus are sent from the memory resources , the 
unidirectional pull bus allowing the memory resources to pull data to the memory resources. 

56. (Currently Amended) A data processor comprising: 
a plurality of programming engines; 

a push bus arbiter to arbitrate use of a push bus by a plurality of external memory 
resources that are external to the data processo r in which requests for using the push bus are sent 
from the memory resources , the push bus arbiter being internal to the data processor, the push 
bus to push data from the memory resources to an input transfer memory associated with the 
programming engines; and 

a pull bus arbiter to arbitrate use of a pull bus by the external memory resources in which 
requests for using the pull bus are sent from the memory resources , the pull bus arbiter being 
internal to the data processor, the pull bus to pull data from an output transfer memory associated 
with the programming engines and to transfer the data to the memory resources. 

57. (Previously Presented) The method of claim 1 wherein the output transfer 
memory comprises an output transfer register. 

58. (Previously Presented) The method of claim 6 wherein the input transfer memory 
comprises an input transfer register. 
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59. (Previously Presented) The machine-accessible medium of claim 26 wherein the 
output transfer memory comprises an output transfer register. 

60. (Previously Presented) The system of claim 37 wherein the output transfer 
memory comprises an output transfer register. 

61. (Currently Amended) A system comprising: 

a plurality of memory resources, each memory resource being associated with a memory 
controller; 

a plurality of processing agents to access the memory resources; 

a unidirectional push bus to push data from the memory resources to the processing 

agents; 

a push bus arbiter to arbitrate use of the push bus by the memory resources in which 
requests for using the push bus are sent from the memory resources , the memory resources 
obtaining access to the push bus based on arbitration by the push bus arbiter; 

a unidirectional pull bus to receive data from the processing agents and to transfer the 
data to the memory resources; and 

a pull bus arbiter to arbitrate use of the pull bus by the memory resources in which 
requests for using the pull bus are sent from the memory resources , the memory resources 
obtaining access to the pull bus based on arbitration by the pull bus arbiter. 

62. (New) The system of claim 13 wherein the memory resources comprise random 
access memory devices. 

63. (New) The system of claim 13 wherein each of the requests for use of the push 
bus or pull bus sent from the memory resources comprises a target identifier identifying a target 
to receive data pushed from or pulled to the memory resources. 
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64. (New) The method of claim 49 wherein the memory resources comprise random 
access memory devices. 

65. (New) The method of claim 49 wherein each of the requests for use of the push 
bus or pull bus sent from the memory resources comprises a target identifier identifying a target 
to receive data pushed from or pulled to the memory resources. 



